Q2

-Input evnt high when conditions met(done)

-Internal counter that counts number of cycles which evnt is high (done)

-When count exceeds threshold(6 bit thresh input), asserts alarm output

and stops counter(done)

-rst(done)

-alarm is a combinational circuit determined form count value and threshold

Module alarmsound(input evnt, clk, rst,sel, [5:0]thresh,

Output ~~reg~~ alarm);

Reg [5:0] count;

always@(posedge clk)

begin

~~if(evnt)~~

if(rst)

count<=6’b000000;

else

if((evnt)&&(!alarm))

count <= count +1’b1;

end

assign alarm = (count >thresh);

endmodule

~~count<= count +1’b1;~~

~~if (count>thresh)~~

~~count<=thresh+1’b1;~~

~~alarm ==1’b1;~~

~~else~~

~~alarm ==1’b0;~~

~~end~~

~~endmodule~~

Q3a)

Module bcount(input clk, rst,

Output reg[4:0] q );

always@(posedge clk)

begin

if(rst)

q<= 5’b00000;

else begin

~~q<= q+1’b1;~~

if(q== 5’b10101)

q<=5’b00000;

else

q <=q+1’b1;

end

end

endmodule

b)

Module bcount(input clk, rst, [4:0]countmax~~[4:0]~~,

Output reg[4:0] q );

always@(posedge clk)

begin

if(rst)

q<= 5’b00000;

else begin

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAMAAAADCAMAAABh9kWNAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAMUExURQCLOQCMOgCLOgAAAKTo33AAAAAEdFJOU////wBAKqn0AAAACXBIWXMAAA7DAAAOwwHHb6hkAAAADElEQVQYV2OAAwYGAAAMAAEIsxKgAAAAAElFTkSuQmCC)

~~q<= q+1’b1;~~

if(q== countmax~~+1~~)

q<=5’b00000;

else

q<=q+1’b1;

end

end

endmodule

c)

Module bcount(input clk, rst, [5:0]start\_val,

Output reg[5:0] q );

always@(posedge clk)

begin

if(rst)

q<= start\_val;

else

q<= q-1’b1;

end

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEkAAABTCAMAAADk4NoTAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAB1UExURQAAAACRNgCLOQCMOQCLOwCMOgCLOgCKOACKOgCTNQCNOwCJOgCOOgCMPwCNOACQNwCKOQCNOgCLNwCIMwCTOgCLPACPNwCMOwB/KgCNOQCLPQCPOgCOPAB/AACHPACGNQCJOAB/PwCMNwCKOwCHNwCRSAAAAHwwRhEAAAAndFJOU///////////////////////////////////////////////////AINWl9kAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAIESURBVFhHrZjLtoMgDEWdOnCUb6j//4k9AVFQQh6w76Rd63Y3OUTQbucSiM41Jjr2Y43poGNNTbTMtNPvXGJCSbTElHpbYjq4txUm+nFvC0wQ7enFrKlUNG/aU9rMpOlaN2bOhN7SujFzpjskMGUi1HS9nDOhtUc0YyLaK9GM6XcvWyJuakICYRM23EYUNz0jeRE1YStpS4qa4HmJgiZst/dVUoiZPq2BkAk7QN7daiKmTkggZPqGBAKmfLx98JvQW6+kgKlfUcDUG4CE19RfN8ZpwgYgiLwmOl47wIPPhK1EKslpEuMGLpOYNuMx4SzpzmTGZZJDAg7T+zB5YTcpIodpGDcwmyAaxA2sJq03u0nrzWzSSzKa4NFERtNwuC9MJuEMaDGZhDOgxWIaX28Fg8mwbozBVB5xFHQTDfbuGtVk7M1gMsxkRjPhgDP1ppuMIQHFZA0JjE2WK7cwNHlE54ZxEf9b23AbNnyvlGn7/Kax4WAVTK/nNw3kJH2zXGwXNvXTMF8mF7x23RXyhQTYRPu3DWdIgE29OzVnSIBN/NiX3jx4QwLJhI+1n/s85BpIpvcgoFtvb8WE6axUeOO4SgrZ1BY1uleWKabqw+5Jylym6nT0T1LmNpUTG9utP22mmPhmG3XxDwqmc/LLbeLxTH+h1sBjgoojirUGKhOyikxk5jz/BVZqb6A2kLIAAAAASUVORK5CYII=)

endmodule